Skip to content

Conversation

@wei-juncheng
Copy link

@wei-juncheng wei-juncheng commented Jun 15, 2025

Closes #127264

What

Issue #127264 pointed out that users relying on exists() as a safe pre-check for resolve() may still encounter an unexpected FileNotFoundError when the cwd is gone. This note:

  • Explains the underlying cause (the getcwd() call).
  • Warns that non-strict mode isn’t immune to failing when the cwd is deleted.
  • Reminds users that a pre-check with exists() can race with filesystem changes.

How

  • Added a “.. note::” under the “Expanding and resolving paths” section of Doc/library/pathlib.rst to document that Path.resolve(strict=False) will call os.getcwd() internally and thus can raise FileNotFoundError if the current working directory has been deleted.

📚 Documentation preview 📚: https://cpython-previews--135531.org.readthedocs.build/

@python-cla-bot
Copy link

python-cla-bot bot commented Jun 15, 2025

All commit authors signed the Contributor License Agreement.

CLA signed

@uranusjr
Copy link
Contributor

Should we also add this to os.path.realpath documentation?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

awaiting review docs Documentation in the Doc dir skip news

Projects

Status: Todo

Development

Successfully merging this pull request may close these issues.

pathlib: Path('.').exists() returns True when current working directory (cwd) was deleted

2 participants